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ABSTRACT 



A session is conducted with an application resident on a host 
computer by loading terminal information at a computer, 
operatively associated with the host computer and which is 
part of a network including a plurality of resource locations, 
from a host access resource location of the plurality of 
resource locations. The terminal emulation information is 
processed to conduct a session between the computer and 
the application. A resource location of the plurality of 
resource locations is then accessed from the computer while 
the session persists. The terminal emulation information 
may be downloaded to the computer from a server of the 
network. According to one aspect, a common environment 
capable of being produced under a plurality of different 
computer operating systems, e.g., a Java environment, is 
produced at the computer. The terminal emulation informa- 
tion is processed under the common environment to thereby 
conduct a session between the computer and the application. 
According to another aspect, the terminal emulation infor- 
mation is processed to instantiate a Session Object at the 
computer, the Session Object being configured to conduct 
the session between the computer and the application. A 
plurality of host access processing objects may be instanti- 
ated from the Session Object, the host access processing 
objects being configured to conduct the session between the 
computer and the application and having methods which are 
accessible to an application resident at the computer. A 
Session Vector which identifies the instantiated Session 
Object may also be instantiated. 

46 Claims, 6 Drawing Sheets 
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APPARATUS, METHODS AND COMPUTER 
PROGRAM PRODUCTS FOR CONDUCTING 
A PERSISTENT SESSION WITH A HOST- 
BASED APPLICATION 

FIELD OF THE INVENTION 

The present invention relates to data processing apparatus 
(systems), methods and computer program products, more 
particularly, to apparatus, methods and computer program 
products for interfacing with host-based applications. 

BACKGROUND OF THE INVENTION 

The Internet is a decentralized network of computers that 
can communicate with one another via a transmission con- 
trol protocol/internet protocol (TCIP/IP). Although the Inter- 
net has its origins in a network created by the Advanced 
Research Project Agency (ARPA) in the 1960's, it has only 
recently become a worldwide communication medium. To a 
large extent, the explosive growth in use of the Internet is 
due to the development in the early 1990's of the worldwide 
Web (WWW), which is one of several service facilities 
provided on the Internet. Other facilities include a variety of 
communication services such as electronic mail, telnet, 
usenet newsgroups, internet relay chat (IRC), a variety of 
information search services such as WAIS and Archie, and 
a variety of information retrieval services such as FTP (file 
transfer protocol) and Gopher. 

The WWW is a client-server based facility that includes 
a number of servers (computers connected to the Internet) on 
which Web pages or files reside, as well as clients (Web 
browsers) which interface the users with the Web pages. 
Specifically, Web browsers and software applications such 
as WebExplorer® (IBM Corporation) or Navigator® 
(Netscape Communication Corporation) send a request over 
the WWW to a server requesting a Web page identified by 
a Uniform Resource Locator (URL) which notes both the 
server where the Web page resides and the file or files on that 
server which make up the Web page. The server then sends 
a copy of the requested file(s) to the Web browser, which in 
turn displays the Web page to the user. 

The Web pages on the WWW may be hyper-media 
documents written in a standardized language called Hyper- 
Text Markup Language (HTML). A typical Web page 
includes text together with embedded formatting commands, 
referred to as tags, which can be used to control font size, 
font style and the like. A Web browser parses the HTML 
script in order to display the text in accordance with the 
specified format. 

Although many new computer applications are being 
developed for distributed processing environments such as 
the Web, there is still a large installed base of traditional 
computer systems having an architecture including a central 
host computer, typically a mainframe, and "dumb" computer 
terminals which are directly connected to ports of the host 
computer. Examples of such a configuration include 3270, 
5250 and VT configurations in which a terminal communi- 
cates with a host according to a variety of networking 
protocols such as SNA or TCP/IP. A networking protocol 
typically provides for structured organization of a data 
stream to include a series of control characters followed by 
a block of displayable characters, a typical data stream 
comprising a plurality of sequentially transmitted control 
character blocks followed by displayable character blocks. 

Because of the continued presence of such host -based 
applications, there is a need for techniques to integrate 
host-based content into the Web paradigm. For example, 
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many companies have centralized information databases, 
services and the like which are accessible to employees from 
terminals or personal computers running terminal emulation 
software. Many companies desire to make this content 
5 accessible to customers through the Internet or to employees 
through an "intranet" which has a Web-like structure and 
user interface. 

Conventional approaches for providing such access typi- 
cally use conversion/translation techniques that employ 

10 emulation software resident at an intermediate Web server. 
Additional code typically executes on top of the emulation 
software that is capable of establishing a session from the 
intermediate server to a host and converting emulation 
screen output/input into a format understood by the browser, 

is such as HTML files, Java GUI applets, or ActiveX controls. 
The intermediate code typically employs a private protocol 
to control the exchange of data between the server and 
browser in the converted format. 

There are several potential problems with this technique. 

20 For example, use of an intermediate server may make it 
difficult to navigate a host session as if it were an integral 
part of a browser environment. The state of the host session 
typically is not maintained in real time on the browser, so 
user may respond to an inappropriate screen. In addition, 

25 when a user leaves a session to surf other Web pages and 
comes back, the session may be disconnected or disrupted. 

The use of the intermediate server may also introduce 
security and other management problems. A session typi- 
cally remains open on the intermediate server, allowing 

50 unauthorized parties to gain access to and control over the 
session. The intermediate server software may also intro- 
duce problems in managing sessions, a function which 
generally is better left to host communications server soft- 
ware which has session-based resource tuning and load 

35 balancing capabilities. In addition, the software used on the 
intermediate server typically is a closed, platform-specific 
executable program which may be inaccessible to develop- 
ers seeking to develop related applications. 

40 SUMMARY OF THE INVENTION 

In light of the foregoing, it is an object of the present 
invention to provide apparatus, methods and computer pro- 
gram products for conducting a session between a computer 
and a host-based application which do not require mediation 
of a session by an intermediate server. 

It is another object of the present invention to provide 
apparatus, methods and computer program products for 
conducting a session between a computer and a host-based 
50 application that can provide industrial-standard open solu- 
tions. 

It is another object of the present invention to provide 
apparatus, methods and computer program products for 
conducting a session between a computer and a host-based 
55 application which persists notwithstanding subsequent 
access of different resource locations, e.g., Web pages, by 
the computer. 

It is another object of the present invention to provide 
apparatus, methods and computer program products for 

60 conducting a session between a computer and a host-based 
application which use an architecture that is accessible to 
other applications resident at the computer. 

These and other objects, features and advantages are 
provided according to the present invention by apparatus 

65 (systems), methods and computer program products in 
which a computer loads terminal emulation information 
from a host access resource location, e.g., Web page, of a 
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network including the computer, and processes the loaded processed to conduct a session between the computer and 

terminal emulation information to conduct a session with an the application. A resource location of the plurality of 

application on a host computer. The terminal emulation resource locations is then accessed from the computer while 

information is configured such that is causes the session to the session persists. The computer may have a browser 

persist when the computer subsequently accesses a resource 5 resident thereat which is operative to access the plurality of 

location of the network. Processing of the terminal emula- resource locations, and the terminal emulation information 

tion information preferably causes the instantiation of an may be loaded by accessing the host access resource loca- 

object structure at the computer that is accessible to other tion from the browser. After the terminal information is 

applications resident at the computer. processed to conduct a session, a resource location of the 

The downloaded terminal information may be automati- 10 plurality of resource locations may then be accessed from 

cally processed upon downloading from a server to auto- ^e browser while the session persists. The terminal emula- 

matically establish a session between the remote computer ton information may be downloaded to the computer from 

and the application, or a user input may be accepted to a server of the network. 

initiate a session. For example, a user may access a location According to an aspect of the present invention, a corn- 
identified by a Uniform Resource Locator (URL) by select- 15 mon environment capable of being produced under a plu- 
ing an HTML link from a Web page displayed on the rality of different computer operating systems is produced at 
computer. Selection of the URL may cause an applet to be the computer. The terminal emulation information is pro- 
downloaded from the server and processed in a Java envi- cessed under the common environment to thereby conduct a 
ronment on the computer to conduct a persistent session session between the computer and the application. The 
between the computer and the host-based application. 20 common environment may comprise a Java environment 
Alternatively, means may be provided in the Web page for and the terminal emulation information may comprise a Java 
accepting user selection of a configuration option for a applet. 

session, and for conducting a session according to the According to another aspect of the present invention, the 

selected configuration option. terminal emulation information is processed to instantiate a 

By storing terminal emulation information which can be 25 Session Object at the computer, the Session Object being 

run on a wide variety of platforms and which is may be configured to conduct the session between the computer and 

downloaded on demand, the present invention offers the application. A plurality of host access processing objects 

improved security and management without requiring modi- may be instantiated from the Session Object, the host access 

fication of existing network configurations or special inter- processing objects being configured to conduct the session 

mediate software or hardware. By making sessions persist 30 between the computer and the application and having meth- 

during access of resource locations by the computer, the ods which are accessible to an application resident at the 

context of a session may be preserved when a user at the computer. A Session Vector which identifies the instantiated 

computer "surfs" among Web pages. Session Object may also be instantiated. 

The present invention also offers a solution which is 35 According to another aspect, processing of the terminal 

platform independent and dynamic, which can be plugged emulation information causes a browser resident at the 

into other networking solutions easily and which has an computer to display a host access Web page including a 

object-oriented structure which offers flexibility for software session configuration option. A user selection of the session 

developers to develop customized applications. configuration option from the host access Web page is 

The present invention takes advantage of platform- 40 accepted, causing the computer to conduct the session 

independent processing environments such as Java techno!- according to the selected configuration option, 

ogy and its applet download capability. This technology can A system for conducting a session with an application 

be used to create a processing structure that breaks the resident on a host computer includes a computer which is 

traditional session model into several discrete self-contained operatively associated with the host computer and which is 

processing points or objects. These objects may be imple- 45 part of a network including a plurality of resource locations, 

mented as Java class files, with a class library being installed Means are provided for accessing information at the plural- 

on a server path of a Web server home directory structure. ity of resource locations from the computer, the means for 

A Web administrator can simply set up a URL pointing to a accessing including means for loading terminal emulation 

default Host On -Demand applet initiation HTML page. information at the computer from a host access resource 

When Web users click on this URL to get the page, it can 50 location of the plurality of resource locations. The computer 

cause a download of required Java class files from the Web is configured to process the loaded terminal emulation 

server to run in the Web user's memory and automatically information to conduct a session between the computer and 

establish a session from the Web user to a host-based the application which persists when the computer subse- 

application which can have end-to-end persistent character- quently accesses a resource location of the plurality of 

istics similar to a session established from a resident emu- 55 resource locations. The means for accessing may comprise 

lation package. Because the Host On-Demand code can be a browser, resident at the computer and operative to access 

simply plugged into an existing environment, extensive the plurality of resource locations, which accesses the ter- 

software modifications are not required and system man- minal emulation information at the host access resource 

agement functions can be left to existing communication location. The session conducted between the computer and 

servers. 60 me a Ppfi ca h° n is configured to persist when the browser 

In particular, according to the present invention, a session subsequently accesses a resource location, e.g, another Web 

is conducted with an application resident on a host computer P*ge, of the plurality of resource locations. The computer 

by loading terminal information at a computer, operatively may be configured to automatically process the terminal 

associated with the host computer and which is part of a emulation information in response to loading of the terminal 

network including a plurality of resource locations, from a 65 emulation information at the computer, 

host access resource location of the plurality of resource In another embodiment according to the present 

locations. The loaded terminal emulation information is invention, the computer is configured to produce a common 
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environment capable of being produced under a plurality of 
different computer operating systems. The terminal emula- 
tion information comprises terminal emulation configured to 
be processed under the common environment. The computer 
is configured to process the loaded terminal emulation 
information under the common environment and thereby 
conduct a session between the computer and the application. 
The common environment may comprise a Java 
environment, and the terminal emulation information may 
comprise a Java applet. The means for accessing may 
comprise means, responsive to a request from the computer, 
for loading the Java applet at the computer. The computer 
may be configured to process the loaded Java applet under 
the Java environment to conduct a session between the 
computer and the application. 

In another embodiment according to the present 
invention, the terminal emulation information is configured 
to cause the computer to instantiate a Session Object when 
processed at the computer, the Session Object being con- 
figured lo conduct the session between the computer and the 
application. The Session Object may be configured to instan- 
tiate a plurality of host access processing objects which 
conduct the session between the computer and the 
application, the host access processing objects having meth- 
ods which are accessible to an application resident at the 
computer. The terminal emulation information may also be 
configured to cause the computer to instantiate a Session 
Vector for identifying the instantiated Session Object. 

In yet another embodiment, the terminal emulation infor- 
mation is configured to cause a browser at the computer to 
display a host access Web page including a session configu- 
ration option and to provide means for accepting a user 
selection of the session configuration option from the host 
access Web page. The terminal emulation information may 
be configured to cause the computer to conduct the session 
according to the selected configuration option. 

An apparatus for conducting a session with an application 
resident on a host computer according lo the present inven- 
tion includes a computer configured to access a plurality of 
resource locations of a network including the computer, to 
load terminal information at the computer from a host access 
resource location of the network and lo process the loaded 
terminal emulation information. Terminal emulation infor- 
mation is loaded at the computer, and is configured to be 
processed at the computer to conduct a session between the 
computer and the application which persists when the com- 
puter subsequently accesses a resource location of the plu- 
rality of resource locations. 

A computer program product for conducting a session 
with an application resident at a host computer according to 
the present invention includes a computer-readable program 
storage medium having computer-readable terminal emula- 
tion information embodied therein which is configured to be 
loaded at a computer connected to the host computer from 
a host access resource location of a network including the 
computer, and which is configured to be processed at the 
computer to thereby conduct a session with the application 
which persists when the computer subsequently accesses a 
resource location of the plurality of resource locations. The 
computer-readable terminal emulation information may 
comprise a Java applet configured to be processed under a 
Java environment at the computer. 

Improved apparatus, methods and computer program 
products for conducting sessions with a host -based applica- 
tion are thereby provided. 

BRIEF DESCRIPTION OF THE DRAWINGS 
Some of the objects and advantages of the present inven- 
tion having been stated, others will be more fully understood 
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from the detailed description that follows and by reference 
to the accompanying drawings in which: 

FIG. 1 is a schematic diagram illustrating a data process- 
ing system in which the methods and apparatus of the 
5 present invention may be embodied; 

FIG. 2 is a schematic diagram illustrating a system for 
conducting sessions with a host-based application according 
to the present invention; 

FIG. 3 is a schematic diagram illustrating a preferred 
embodiment of a system for conducting sessions with a 
host-based application according to the present invention; 

FIG. 4 is a flowchart illustration of operations for con- 
ducting a session with a host-based application according to 
15 the present invention; 

FIG. 5 is a schematic block diagram illustrating an 
exemplary object structure for conducting a session with a 
host-based application according to the present invention; 

FIGS. 6-9 are flowchart illustrations of exemplary opera - 
20 tions for conducting a session with a host-based application 
according to the present invention; and 

FIG. 10 illustrates a host access Web page according to 
the present invention. 

25 DETAILED DESCRIPTION OF PREFERRED 
EMBODIMENTS 

The present invention now will be described more fully 
hereinafter with reference to the accompanying drawings, in 

3Q which embodiments of the invention are shown. Those 
skilled in the art will appreciate that the invention may be 
embodied in many different forms and should not be con- 
strued as limited to the embodiments set forth herein; rather, 
these embodiments are provided so that this disclosure will 

35 be thorough and complete, and will fully convey the scope 
of the invention to those skilled in the art. In the drawings, 
like numbers refer to like elements throughout. 

In the discussion that follows, reference is made to 
"application." For purposes of the discussion here, "appli- 

40 cation" refers to terminal-type host-based applications. 
These applications include, but are not limited to, such 
mainframe applications as 3270, 5250 and ASCII VT appli- 
cations which use screen-type user interfaces to display and 
receive data from a user at a terminal connected to the 

4S mainframe computer. 

The description herein also refers to "objects," i.e., pro- 
cessing structures created according to object-oriented pro- 
gramming principles. Those skilled in the art will appreciate 
that, in general, objects are programming models which 

50 generally are defined by "state" and "behavior." In the 
programming implementation of an object, the state of an 
object is defined by its fields, which may or may not be 
accessible from outside of the object. An object's behavior 
is defined by its methods, which manipulate instance vari- 

55 ables (data for the object) to create new state, and which also 
can create new objects. Typically, the object's methods are 
the only means by which other objects can access or alter its 
instance variables, with objects interacting with one another 
via messages. Object-oriented programming techniques are 

60 utilized in many modem programming languages, including 
C++ and Java. 

Those skilled in the art will appreciate that although the 
description herein makes use of object-oriented program- 
ming concepts, the present invention may be embodied 

65 using other techniques which may not be considered "object 
oriented." For example, the present invention may be imple- 
mented using more a traditional procedural framework that, 
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in effect, embodies functionality also attainable using FIG. 2 illustrates an embodiment of the present invention, 

object-oriented principles. Accordingly, those skilled in the in particular, a cl[ent/seryer,architecture used to provide a 

art will appreciate that the present invention is applicable to terminal interf ace to a hos t-based computer a pplicationfrom 

object-oriented and non-object-oriented environments. a remote-termin al usin g terminal emulation informat ion 

To provide an example of an object-oriented environment 5 slored^on^serve x external to the rem ote_computer. A 

in which the systems, methods and computer program network 105 includes a remote computer llO coDfi gured to 

products of the present invention may be embodied, the download.teniimaLemulation^infongati on 232 stored _a t a 

discussion herein describes a Java environment. Java is an hos Laccess resource location 230,_e ? g,, _a storage locati on 

object-oriented programming language developed by Sun located at a server 130 that is addressable usin g^a URL. For 

Microsystems, Mountain View, Calif. Java is designed to be 10 example^ the terminal .emulation information^may^be 

portable and architecturally neutral, making it advantageous acc essed by selectin g a bookm ark 214 displayed.b.vjL Web 

for distributed processing applications in which computers browser 210jrunning_at_t_h e remo te ^comp uter HQ, or J?y 

having a variety of different operating systems are intercon- se lecting of a HTM L linkjn^Web page displa yed at the 

nected. Java source code is compiled into a machine- re mote comp u ter lYO'In^ r^n ^to selec tion of the a ppro- 

independent format that can be run on any platform with a 15 pr iate rxwkmark/ t hejermi^^ information 232 is 

Java runtime system known as the Java Virtual Machine do wnlpad e oLto the remo te^c^pjijejll^ 

(JVM). The JVM is a process that emulates a virtual access resource location 230. 

processor through the use of software on a real machine, i ne remoie" computer 110 is configured to process the 

allowing Java software to execute under diverse operating downloaded terminal emulation information 216 to conduct 

systems, including UNIX, Windows NT, and Macintosh. 20 a persistent session with an application 240 resident at the 

Web browsers including Netscape Navigator® and host computer 140, i.e., a session which persists when the 
Microsoft Internet Explorer® are referred to as Java-enabled remote computer 110 accesses a resource location in the 
browsers because they include a version of the JVM. Java network 105. For example, after the Web browser 210 
applets are programs written in Java and configured to run accesses the host access resource location 230 and down- 
within Java-enabled browsers. Handled in a manner similar 2 s loads the terminal emulation information 232, the down- 
to the way images are handled, Java applets may be dis- loaded terminal emulation information may be automati- 
played as part of a HyperText Mark Up Language (HTML) cally processed to establish a session between the remote 
document. When an applet is loaded, it can present special computer 110 and the host computer 140. The session 
effects, such as animation, graphics, and sound, perform established persists when the Web browser 210 accesses a 
real-time data updates and applications, and can interact 30 resource location, for example, when the browser 210 
with a user through a mouse, keyboard and various interface reloads information, e.g., a Web page, from the host access 
elements such as buttons, slides and text fields. resource location 230 or when the browser 210 loads infor- 

Java source code is compiled into bytecode using a Java mation from another resource location in the network 105. 

compiler referred to as a Javac. Compiled Java programs are A preferred embodiment of the present invention is illus^\ 

saved in files with the extension "class". When a Java- 35 trated in FIG. 3. The remote computer 110 is configured to 

enabled Web browser recognizes that an applet has been produce a platform-independent common environment, for 

requested, a Java interpreter processes the applet bytecode example, a Java environment 316 (or, in Java nomenclature, 

on the JVM. The Java programming language and environ- a Java Virtual Machine). The terminal emulation informa- 

ment is extensively described in "The Java Tutorial: Object- tion includes a Java applet 332, which is stored on the server 

Oriented Programming for the Internet/* by Mary Carapione 40 130 at the host access resource location 230. The Java applet 

and Kathy Walrath, published by Addison- Wesley Pub Co 332 is downloaded to the remote computer 110 to be, 

(1996). processed under the Java environment 316 to establish and 

FIG. 1 illustrates a computer system in which the methods conduct a session between the remote computer 110 and the 

and apparatus of the present invention can be embodied. A application 240 on the host computer 140. For example, 

network 120 includes a remote computer 110, e.g., a per- 45 processing of the downloaded Ja^^ppje^ll^may^ause the 

sonal computer including such components as a central remote computer to establish a user interface for the 

processing unit (CPU) 112, a display 114 and user input application, as well as control communications between the 

devices such as a keyboard 116 and a mouse 118. The remote remote computer 110 and the application 240 according to, 

computer 110 is connected to a server 130 of the network the protocol required by the application 240, e.g., a TN3270 

120, as well as to a host computer 140. Those skilled in the 50 protocol. Those skilled in the art will appreciate that 

art will appreciate that the remote computer 110 may take although FIGS. 2 and 3 Ulustrate a direct connection 

other forms than the personal computer illustrated; for between the rejno^£omputer_ho: c andahe^b ost com puter 

example, the remote computer 110 may include a so-called 140, communications therebetween may occur through one 

"network computer," i.e., a Web-enabled terminal with little or more intermediate devices. For example, a Java security 

or no local disk storage, or other computing device such as 55 framework may require connection of the remote computer 

a personal digital assistant (PDA), personal communications HO and the host computer 140 through a server, 

system (PCS), or the like. Those skilled in the art will also Although the embodiments illustrated in FIGS. 2 and 3 

appreciate that the server 130 make take various forms involve downloading of an applet from a server 130 which 

including conventional personal computer type servers or is part of a network that includes the remote computer 110, 

similar devices which may be addressable as locations in a 60 the present invention can also be implemented by loading 

network and have the capability to store information. terminal emulation information at the remote computer 110 

Although host computer 140 may take the form of a tradi- in other ways. For example, the terminal emulation infor- 

tional mainframe computer running a conventional terminal mation may comprise a Java applet that is stored at a local 

application such as a 3270 application, those skilled in the resource location at the remote computer 110, e.g., on a hard 

art will appreciate that the host computer 140 may comprise 65 drive, diskette, CDROM, or similar storage medium. The 

various other apparatus that run applications that conduct locally stored terminal emulation information may loaded 

input and output using a terminal-type interface. directly by the browser 210 without requiring a network 
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transfer and used to conduct a persistent session between the Object sess3270 that conducts a session between the remote 

remote computer 110 and the host application 240. computer 110 and the host-based application 240. According 

FIG. 4 illustrates basic operations for conducting a per- to the illustrated embodiment, the Session Object sess3270 

sistent session between a remote computer and a host-based further instantiates a plurality of host access processing 

application according to the present invention (Block 400). 5 objects including a Transport Object tn3270, a Data Stream 

A user at the remote computer provides a request to access Object ds3270 and a Presentation Space Object ps3270. The 

the hostbased application by, for example, selecting an Transport Object tn3270 is responsible for session 

HTML link in a Web page displayed at the remote computer negotiation, termination, and flow control of 3270 data 

(Block 410). In response, terminal emulation information, streams over sockets. Outbound 3270 data streams (host to 

e.g., a Java applet, is downloaded to the remote computer 10 Web user) are parsed in the Data Stream Object ds3270 into 

from a server in a network connected to the remote computer discrete tokens and passed onto the Presentation Space 

(Block 420). The downloaded terminal emulation informa- Object ps3270. The Presentation Space Object ps3270 main- 

tion is then processed to conduct a persistent session tains a 3270 presentation space at the remote computer 110, 

between the remote computer and the application (Block including data fields, by processing these tokens. The Pre- 

430), e.g., a session which persists when the remote com- 15 sentation Space Object ps3270 also takes user input, updates 

puter accesses another Web page (Block 440). The process- the presentation space, and initiates inbound 3270 data 

ing of the downloaded emulation information may occur streams (Web user to host). Inbound data streams are 

automatically after downloading, or may be delayed until an assembled by the Data Stream Object ds3270 with tokens 

appropriate user command is submitted. obtained from the Presentation Space Object ps3270 and 

As known to those skilled in the art, a remote computer 2 o V^^d onto the Transport Object tn3270 for transport. These 

may access a Web page by establishing TCP/IP communi- classes are glued together by the Session Object sess3270 to 

cations with a server hosting the Web page, more represent the complete state of a session. Multiple host 

specifically, with a resource location identified by a Uniform connections may be created by instantiating multiple Ses- 

Resource Locator (URL). Typically, the server is a personal sion Objects, which may in turn be identified by a Session 

computer, mainframe computer, minicomputer, or similar 2 s Vector 540 maintained at the remote computer 110. Each 

data processing device having a data processor and data host connection may be tracked in the Session Vector 540 as 

storage capability, and data transferred between the remote a separate Session Object instance. 

computer and the server are processed according to the In greater detail, the Session Object sess3270 of the 

HyperText Transfer Protocol (HTTP). To access a Web page illustrated embodiment establishes and maintains a connec- 

hosted at a server, a remote computer, via a Web browser or 30 tion with the host-based application 240. The behavior and 

similar interface, sends a TCP/IP message to the server that characteristics of this connection may be controlled through 

represents a request for the Web page. Data for the Web page a set of key properties which may include host name and 

are transferred to the remote computer, and the Web page is port number, terminal connection types, session identifier, 

generated on the display of the remote computer from the presentation space size, host code pages, host control 

transferred objects. Accordingly, for purposes of the discus- 35 characters, and the like. In object-oriented terms, the Session 

sion herein, "Web page" may refer to both the resource Object sess3270 may be considered a master class that 

location (URL) used to access a Web page, and the actual instantiates other host access objects such as the Transport 

physical display of the Web page at a computer accessing the Object tn3270, the Data Stream Object ds3270 and the 

Web page. Presentation Space Object ps3270. The Session Object may 

As known to those of skill in the art, a Java applet may be 40 nave methods which are accessible to these host access 

embedded in an hypertext markup language (HTML) docu- objects, i.e., "internal" methods, as well methods accessible 

ment via an "applet tag." This tag is used to describe the to other applications resident at the remote computer 110, 

applet, its parameters, and its dimensions. When an applet i.e., "extemar methods. External methods may include 

tag is activated, the Web browser accessing the HTML starting or stopping a session, returning property values, and 

document downloads code for the applet from a specified 45 returning identifiers of objects that provide external meth- 

server, and executes the code on the computer at which the ods. Internal methods may include setting property values, 

browser is operating. As will be appreciated by those skilled starting and stopping error reporting, and returning identi- 

in the art, applet activation can be automatic, e.g., upon fiers of other objects. 

access to the HTML document, or may be activated by a user The Presentation Space Object ps3270 of the illustrated 

action such as selection of a button or similar object in the 50 embodiment maintains a virtual host display screen for a 

displayed document. Accordingly, establishment of a ses- session. The behavior and characteristics of the presentation 

sion as described above may occur upon access to a Web space may be based on terminal connection type and pre- 

page having an applet tag embedded therein, or may be sentation space size session properties. The Presentation 

initiated by selection of an item on such a page. An extensive Space Object ps3270 holds formatted screen data and 

description of HTML is provided by the "HTML Reference 55 attributes and provides methods for extracting and entering 

Manual," published by Sandia National Laboratories (1996), information in the presentation space. External methods for 

available on the World Wide Web at http://www.sandia.gov/ this object may include getting and setting presentation 

sci_compute/html_ref.html. space content, getting and setting field content, getting field 

FIG. 5 illustrates an object structure for conducting per- attributes, navigating fields, accepting keyboard, function 

sistent sessions according to the present invention, in 60 key and other user inputs, and the like. These external 

particular, a structure employed in an IBM Host-On- methods may be used by the Data Stream Object ds3270, as 

Demand vl.O product developed by the assignee of the well as by other applications resident at the remote computer 

present application. Processing of downloaded terminal HO, to assemble data streams for communication to the 

emulation information as described above causes creation of application 240. 

host access processing means 520 for conducting a session 65 The Data Stream Object ds3270 of the illustrated embodi- 

between the remote computer 110 and the host-based appli- ment parses and assembles host data streams. Methods for 

cation 240, more particularly, instantiation of a Session this object may include sending and receiving host applica- 
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tion format data streams. For example, the Transport Object 
tn3270 may use a "receive data" method of the Data Stream 
Object ds3270 to pass a host data stream from the applica- 
tion 240 onto the Presentation Space Object ps3270. 
Similarly, the Presentation Space Object ps3270 may use a 
"send data" method of the Data Stream Object ds3270 to 
request assembly of a data stream for transmission to the 
host application 240 via the Transport Object tn3270. 

The Transport Object tn3270 sends and receives data 
streams according to a communications protocol, e.g., TCP/ 
IP, used by the host computer 140. The behavior and 
characteristics of the Transport Object tn3270 may be con- 
trolled by properties such as protocol type, host name, and 
port number. Internal methods may include reading an input 
stream, writing and output stream, and stopping transport. 
For example, a "read input stream" method may be used by 
the Transport Object tn3270 to extract a host application 
format data stream from data which is formatted according 
to the communications protocol used by the host computer 
140. 

The result is an object structure which is configured to 
conduct a persistent session from the Web user to the 
host-based application, and which may be accessed by other 
applications at various levels. For example, user interface 
processing 530 and run-time environment processing 510 
can be logically separated from the host access session 
processing 520. Applications such as user interface process- 
ing 530 may include several objects which, for example, 
construct a visual display on the Web user's display 534 and 
which process inputs from input devices 532. These objects 
may be attached to the session object sess3270 from its 
default instantiation method, and may utilize the methods of 
the host access processing objects. Similarly, run-time envi- 
ronment processing 510 can provide a default run time 
control that initiates sessions, maintains session limit, tracks 
user interface options, and resolves file references. The open 
structure of the host access processing 520 allows further 
tailoring and extension of processing for new Web applica- 
tions. 

Operations according to various aspects of the present 
invention, in particular, exemplary operations under the 
structure illustrated in FIG. 5, are illustrated in the flowchart 
illustrations of FIGS. 6-9. It will be understood that each 
block of the flowchart illustrations, and combinations of 
blocks in the flowchart illustrations, can be implemented by 
computer program instructions. These computer program 
instructions may be provided to a processor or other pro- 
grammable data processing apparatus to produce a machine, 
such that the instructions which execute on the processor or 
other programmable data processing apparatus create means 
for implementing the functions specified in the flowchart 
block or blocks. These computer program instructions may 
also be stored in a computer- read able memory that can direct 
a processor or other programmable data processing appara- 
tus to function in a particular manner, such that the instruc- 
tions stored in the computer-readable memory produce an 
article of manufacture including instruction means which 
implement the functions specified in the flowchart block or 
blocks. 

The computer program instructions may also be executed 
by a processor or other programmable data processing 
apparatus to cause a series of operational steps to be per- 
formed by the processor or other programmable apparatus to 
produce a computer implemented process such that the 
instructions which execute on the computer or other pro- 
grammable apparatus provide steps for implementing the 
functions specified in the flowchart block or blocks. 
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Accordingly, blocks of the flowchart illustrations support 
combinations of means for performing the specified 
functions, combinations of steps for performing the speci- 
fied functions and program instruction means for performing 

5 the specified functions. It will also be understood that each 
block of the flowchart illustrations, and combinations of 
blocks in the flowchart illustrations, can be implemented by 
special purpose hardware -based computer systems which 
perform the specified functions or steps, or combinations of 
special purpose hardware and computer instructions. 

Referring now to FIG. 6, to initiate a session (Block 600), 
a user at the remote computer opens a URL to initiate a 
download of a Java applet and processing of the downloaded 
applet (Block 605). The processing of the applet instantiates 
a Session Object, which in turn instantiates host access 

15 processing objects including a Transport Object, Data 
Stream Object and Presentation Space Object (Block 610). 
The Transport Object opens a socket connection to a 3270 
server port (Block 615), setting up a continuous read loop to 
the host computer (Block 620), performing 3270 negotiation 

20 (Block 625), and passing 3270 data streams to the Data 
Stream Object (Block 630). The 3270 data streams may then 
be parsed (Block 635), the data entered in a buffer main- 
tained by the Presentation Space Object (Block 640), and 
field structures constructed (Block 645). A user interface is 

25 then updated at the end of the data stream (Block 650), e.g., 
a data input/output screen is "painted." 

FIG. 7 illustrates operations for conducting inbound (Web 
user to host) traffic (Block 700). A user provides data input 
at the remote computer (Block 705). The data is routed to the 

30 Session Object and handed over to the Presentation Space 
Object (Block 710), after which data in the buffer is modi- 
fied and field structures updated (Block 715). A 3270 data 
stream is then assembled from the data (Block 720), a Telnet 
header and trailer added (Block 725), and the assembled data 

35 stream written to a socket opened for the 3270 communi- 
cations to the host by the Transport Object (Block 730). The 
data stream then flows to the host computer according to the 
host computer's communications protocol (Block 735) 
FIG. 8 illustrates operations for conducting outbound 

40 (host to Web user) traffic (Block 800). A Telnet data stream 
flows from the host computer to the remote computer over 
a socket opened for such a purpose (Block 805). The 
Transport Object removes Telnet control information from 
the data stream, and the remaining 3270 data passed to the 

45 Data Stream Object (Block 810). The data is parsed (Block 
815), and the data buffer and field structures maintained by 
the Presentation Space Object are modified based on the 
parsed data (Block 820). The user interface is then updated 
(Block 825). 

50 FIG. 9 illustrates operations for conducting a session 
having a user-specified configuration according to another 
aspect of the present invention (Block 900). A browser 
resident at a remote computer is caused to display a host 
access Web page including a session configuration option 

55 (Block 910). A user selects a configuration option (Block 
920), and a session is established between the remote 
computer and the host application according to the selected 
configuration option (Block 930). As illustrated in FIG. 10, 
a host access Web page 1000 may include a variety of 

60 user-selectable configuration options, here shown as mouse- 
selectable objects 1010 in the Web page 1000. After selec- 
tion of the desired options, a user may then command 
establishment of a session configured according to the 
selected options by, for example, selecting an appropriate 

65 command button 1020 in the Web page 1000. 

In the drawings and specification, there have been dis- 
closed typical embodiments of the invention and, although 
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specific terms are employed, they are used in a generic and 
descriptive sense only and not for purposes of limitation, the 
scope of the invention being set forth in the following 
claims. 

That which is claimed is: 

1. A system for conducting a session with an application 
resident on a host computer, the host computer configured to 
communicate according to a host communications protocol, 
the system comprising: 

a computer which is operatively associated with the host 
computer and which is part of a network including a 
plurality of resource locations; and 

means for accessing information at said plurality of 
resource locations from said computer, said means for 
accessing including means for loading terminal emu- 
lation information at said computer from a host access 
resource location of said plurality of resource locations, 

wherein said computer is configured to process the loaded 
terminal emulation information to create a process at 
the computer that is operative to conduct a session 
between said computer and the application, the session 
operative to persist when said computer subsequently 
accesses a resource location of said plurality of 
resource locations, the process operative to communi- 
cate with the host computer according to the host 
communications protocol without requiring a protocol 
conversion between the computer and the host com- 
puter. 

2. A system according to claim 1: 

wherein said means for accessing comprises a browser, 
resident at said computer and operative to access said 
plurality of resource locations, which accesses said 
terminal emulation information at said host access 
resource location; and 

wherein said created process is operative to conduct a 
session between said computer and the application that 
persists when said browser subsequently accesses a 
resource location of said plurality of resource locations. 

3. A system according to claim 1, wherein said means for 
accessing comprises means for downloading the terminal 
emulation information from a server of said network. 

4. A system according to claim 1: 

wherein said computer is configured to produce a com- 
mon environment capable of being produced under a 
plurality of different computer operating systems; 

wherein said terminal emulation information comprises 
terminal emulation configured to be processed under 
said common environment; and 

wherein said computer is configured to process the loaded 
terminal emulation information under said common 
environment and thereby conduct a session between 
said computer and the application. 

5. A system according to claim 1: 

wherein said common environment comprises a Java 
environment; 

wherein said terminal emulation information comprises a 
Java applet; 

wherein said means for accessing comprises means, 
responsive to a request from said computer, for loading 
the Java applet at said computer; and 

wherein said computer is configured to process the loaded 
Java applet under said Java environment to conduct a 
session between said computer and the application. 

6. A system according to claim 1, wherein said computer 
is configured to automatically process the loaded terminal 
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emulation information in response to loading of the terminal 
emulation information at said computer. 

7. A system according to claim 1, wherein the terminal 
emulation information is configured to cause the computer 

5 to instantiate a Session Object when processed at said 
computer, said Session Object being configured to conduct 
the session between the computer and the application. 

8. A system according to claim 7, wherein the Session 
Object is configured to instantiate a plurality of host access 

iQ processing objects which conduct the session between the 
computer and the application, said host access processing 
objects having methods which are accessible to an applica- 
tion resident at said computer. 

9. A system according to claim 8, wherein the application 
resident at the host computer is configured to communicate 

15 according to a host application data stream format, wherein 
the host computer is configured to communicate according 
to a host communications protocol, and wherein said plu- 
rality of host access processing objects comprises: 

a Presentation Space Object which maintains a presenta- 
20 tion space at the computer, said Presentation Space 
Object being configured to accept information for pre- 
sentation in said presentation space and to extract 
information from said presentation space; 
a Data Stream Object, operatively associated with said 
25 Presentation Space Object, which is configured to 
receive extracted information from said Presentation 
Space Object and produce a data stream formatted 
according to said host application data stream format 
therefrom, and which is configured to receive a data 
30 stream formatted according to said host application 
data stream format and provide information to said 
Presentation Space Object therefrom; and 
a Transport Object, operatively associated with said Data 
Stream Object and with the host computer, which is 
35 configured to receive a data stream formatted according 
to said host application data stream format from said 
Data Stream Object and provide a data stream format- 
ted according to a host communications protocol to the 
host computer therefrom, and which is configured to 
40 receive a daia stream formatted according to the host 
communications protocol from the host computer and 
to provide a data stream formatted according to the host 
application data stream format to said Data Stream 
Object therefrom. 
45 10. A system according to claim 7, wherein the terminal 
emulation information is configured to cause the computer 
to instantiate a Session vector for identifying the instantiated 
Session Object. 

11. Asystem according to claim 1, wherein the application 
50 is configured to communicate according to a Telnet protocol, 

and wherein the terminal emulation information causes said 
computer to communicate with the application according to 
said Telnet protocol. 

12. A system according to claim 2, wherein the terminal 
55 emulation information is configured to cause said browser to 

display a host access Web page including a session configu- 
ration option and to provide means for accepting a user 
selection of said session configuration option from said host 
access Web page, and wherein the terminal emulation infor- 
60 mation is configured to cause said computer to conduct the 
session according to the selected configuration option. 

13. An apparatus for conducting a session with an appli- 
cation resident on a host computer, the host computer 
configured to communicate according to a host communi- 

65 cations protocol, the apparatus comprising: 

a computer configured to access a plurality of resource 
locations of a network including the computer, to load 
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terminal information at the computer from a host access 
resource location of the network and to process the 
loaded terminal emulation information; and 
terminal emulation information, loaded at the computer, 
which is configured to be processed at the computer to 5 
create a process at the computer that is operative to 
conduct a session between said computer and the 
application, the session operative to persist when said 
computer subsequently accesses a resource location of 
the plurality of resource locations, the created process 10 
operative to communicate with the host computer 
according to the host communications protocol without 
requiring a protocol conversion between the computer 
and the host computer. 

14. An apparatus according to claim 13, further compris- 
ing a browser, resident at said computer and configured to 
access the plurality of resource locations, which accesses the 
terminal emulation information at the host access resource 
location, and wherein the created process is operative to 
conduct a session between said computer and the application 2Q 
that persists when said browser subsequently accesses a 
resource location of the plurality of resource locations. 

15. An apparatus according to claim 13, wherein said 
computer is configured to download the terminal emulation 
information from a server of the network. 25 

16. An apparatus according to claim 13: 

wherein the computer is configured to produce a common 
environment capable of being produced under a plu- 
rality of different computer operating systems; 

wherein said computer is configured to process the loaded 30 
terminal emulation information under the common 
environment to thereby conduct a session between said 
computer and the application. 

17. An apparatus according to claim 16: 

wherein said common environment comprises a Java 35 
environment; 

wherein said computer is configured to download a Java 
applet and to process the downloaded Java applet under 
the Java environment to conduct a session between said 
computer and the application. 40 

18. An apparatus according to claim 15, wherein said 
computer is configured to accept a user input and to com- 
municate a request to the server to download said terminal 
emulation information in response to the user input. 

19. An apparatus according to claim 13, wherein said 45 
computer is configured to automatically process said termi- 
nal emulation information in response to loading of said 
terminal emulation information. 

20. An apparatus according to claim 13, wherein said 
terminal emulation information is configured to cause said 50 
computer to instantiate a Session Object when processed at 
said computer, said Session Object being configured to 
conduct the session between said computer and the appli- 
cation. 

21. An apparatus according to claim 20, wherein the 55 
Session Object is configured to instantiate a plurality of host 
access processing objects which conduct the session 
between the computer and the application, said host access 
processing objects having methods which are accessible to 

an application resident at said computer. 60 

22. An apparatus according to claim 21, wherein the 
application resident at the host computer is configured to 
communicate according to a host application data stream 
format, wherein the host computer is configured to commu- 
nicate according to a host communications protocol, and 65 
wherein said plurality of host access processing objects 
comprises: 



a Presentation Space Object which maintains a presenta- 
tion space at said computer, said Presentation Space 
Object being configured to accept information for pre- 
sentation in said presentation space and to extract 
information from said presentation space; 

a Data Stream Object, operatively associated with said 
Presentation Space Object, which is configured to 
receive extracted information from said Presentation 
Space Object and produce a data stream formatted 
according to said host application data stream format 
therefrom, and which is configured to receive a data 
stream formatted according to said host application 
data stream format and provide information to said 
Presentation Space Object therefrom; and 

a Transport Object, operatively associated with said Data 
Stream Object and with the host computer, which is 
configured to receive a data stream formatted according 
to said host application data stream format from said 
Data Stream Object and provide a data stream format- 
ted according to a host communications protocol to the 
host computer therefrom, and which is configured to 
receive a data stream formatted according to the host 
communications protocol from the host computer and 
to provide a data stream formatted according to the host 
application data stream format to said Data Stream 
Object therefrom. 

23. An apparatus according to claim 20, wherein said 
terminal emulation information is configured to cause said 
computer to instantiate a Session Vector for identifying the 
instantiated Session Object. 

24. An apparatus according to claim 13, wherein the 
application is configured to communicate according to a 
Telnet protocol, and wherein said terminal emulation infor- 
mation is configured to cause said computer to communicate 
with the application according to the Telnet protocol. 

25. An apparatus according to claim 14, wherein said 
terminal emulation information is configured to cause said 
browser to display a host access Web page including a 
session configuration option and to provide means for 
accepting a user selection of said session configuration 
option from said host access Web page, and wherein said 
terminal emulation information is configured to cause said 
computer to conduct the session according to the selected 
configuration option. 

26. A computer program product for conducting a session 
with an application resident at a host computer, the computer 
program product comprising: 

a computer-readable program storage medium having 
computer-readable terminal emulation information 
embodied therein which is configured to be loaded at a 
computer connected to the host computer from a host 
access resource location of a network including the 
computer, and which is configured to be processed at 
the computer to thereby create a process at the com- 
puter that is operative to conduct a session with the 
application which persists when the computer subse- 
quently accesses a resource location of the plurality of 
resource locations, the created process operative to 
communicate with the host computer according to the 
host communications protocol without requiring a pro- 
tocol conversion between the computer and the host 
computer. 

27. A computer program product according to claim 26, 
wherein said computer-readable terminal emulation infor- 
mation comprises a Java applet configured to be processed 
under a Java environment at the computer. 

28. A computer program product according to claim 26, 
wherein said computer-readable terminal information is 
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configured to cause the computer to automatically establish 35. A method of conducting a session with an application 

a session with the application in response to loading of the resident on a host computer, the host computer configured to 

computer-readable terminal emulation information at the communicate according to a host communications protocol, 

computer. the method comprising the steps of: 

29. A computer program product according to claim 26, 5 loading terminal information at a computer, ope rati vely 
wherein the computer-readable terminal emulation informa- associated with the host computer and which is part of 
tion is configured to cause the computer to instantiate a a network including a plurality of resource locations, 
Session Object when processed at the computer, the Session from a host access resource location of the plurality of 
Object being configured to conduct a session between the resource locations; 

computer and the application. 1Q processing the loaded terminal emulation information to 

30. A computer program product according to claim 29, create a process at the computer that is operative to 
wherein the Session Object is configured to instantiate a conduct a session between the computer and the 
plurality of host access processing objects which conduct the application, the created process operative to conduct 
session between the computer and the application, said host me session according to the host communications pro- 
access processing objects having methods which are acces- tocol without requiring a protocol conversion between 
sible to an application resident at said computer. 15 me computer and the host computer; and then 

31. A computer program product according to claim 30, accessin g a resource location of the plurality of resource 
wherein the application resident at the host computer *s locations from the computer while the session persists, 
configured to communicate according to a host application ^ accordi tQ daim 35 wherein the com . 
data stream format, wherein the host computer is configured * ^ 

to communicate according to a host communications 20 v c , , r 

protocol, and wherein said plurality of host access process- access the P luraht y of rescmrce locations, and: 

ing objects comprises: wherein said step of loading comprises the step of access- 

a Presentation Space Object which maintains a presenta- lhe host access resource location from the browser; 

tion space at the computer, said Presentation Space anc * 

Object being configured to accept information for pre- 2 5 wherein said step of accessing comprises the step of 

sentation in said presentation space and to extract accessing a resource location of the plurality of 

information from said presentation space; resource locations from the browser while the session 

a Data Stream Object, opera lively associated with said persists. 

Presentation Space Object, which is configured to 37. A method according to claim 35, wherein said step of 

receive extracted information from said Presentation 30 loading comprises the step of downloading the terminal 

Space Object and produce a data stream formatted emulation information from a server of the network, 

according to said host application data stream format 38. A method according to claim 35, further comprising 

therefrom, and which is configured to receive a data the step of producing a common environment capable of 

stream formatted according to said host application being produced under a plurality of different computer 

data stream format and provide information to said 35 operating systems at the computer, and wherein said step of 

Presentation Space Object therefrom; and processing comprises the step of processing the downloaded 

a Transport Object, operatively associated with said Data terminal emulation information under the common environ- 

Stream Object and with the host computer, which is to thereby conduct a session between the computer and 

configured to receive a data stream formatted according me application. 

to said host application data stream format from said 40 39. A method according to claim 35, wherein the common 

Data Stream Object and provide a data stream format- environment comprises a Java environment, wherein the 

ted according to a host communications protocol to the terminal emulation information comprises a Java applet, 

host computer therefrom, and which is configured to anc * : 

receive a data stream formatted according to the host wherein said step of loading comprises the step of loading 

communications protocol from the host computer and 45 the Java applet at the computer; and 

to provide a data stream formatted according to the host wherein said step of processing comprises the step of 

application data stream format to said Data Stream processing the loaded Java applet under the Java envi- 

Object therefrom. ronment to conduct a session between the computer and 

32. A computer program product according to claim 29, the application. 

wherein said computer-readable terminal emulation infor- 50 40. A method according to claim 35, wherein said step of 

mation is configured to cause the computer to instantiate a processing comprises the step of automatically processing 

Session Vector for identifying the instantiated Session the loaded terminal emulation information in response to 

Object. loading of the terminal emulation information. 

33. A computer program product according to claim 26, 41. A method according to claim 35, wherein said step of 
wherein the application is configured to communicate 55 processing comprises the step of instantiating a Session 
according to a Telnet protocol, and wherein said computer- Object at the computer, the Session Object being configured 
readable terminal emulation information is configured to to conduct the session between the computer and the appli- 
cause the computer to communicate with the application cation. 

according to the Telnet protocol. 42. A method according to claim 41, wherein said step of 

34. A computer program product according to claim 26, 60 processing comprises the step of instantiating a plurality of 
wherein said computer-readable terminal emulation infor- host access processing objects from the Session Object, the 
mation is configured to cause display of a host access Web host access processing objects being configured to conduct 
page including a session configuration option at the the session between the computer and the application and 
computer, to provide means for accepting a user selection of having methods which are accessible to an application 
said session configuration option from said host access Web 65 resident at said computer. 

page, and to cause the computer to conduct the session 43. A method according to claim 42, wherein the appti- 

according to the selected configuration option. cation resident at the host computer is configured to com- 
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raunicate according to a host application data stream format, 
wherein the host computer is configure to communicate 
according to a host communications protocol, and wherein 
said step of instantiating a plurality of host access processing 
objects comprises the steps of: 

instantiating a Presentation Space Object which maintains 
a presentation space at the computer, said Presentation 
Space Object being configured to accept information 
for presentation in said presentation space and to 
extract information from said presentation space; 
instantiating Data Stream Object, operatively associated 
with said Presentation Space Object, which is config- 
ured to receive extracted information from said Pre- 
sentation Space Object and produce a data stream 
formatted according to said host application data 
stream format therefrom, and which is configured to 
receive a data stream formatted according to said host 
application data stream format and provide information 
to said Presentation Space Object therefrom; and 
instantiating a Transport Object, operatively associated 
with said Data Stream Object and with the host 
computer, which is configured to receive a data stream 
formatted according to said host application data 
stream format from said Data Stream Object and pro- 
vide a data stream formatted according to a host 
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communications protocol to the host computer 
therefrom, and which is configured to receive a data 
stream formatted according to the host communications 
protocol from the host computer and to provide a data 
5 stream formatted according to the host host application 
data stream format to said Data Stream Object there- 
from. 

44. A method according to claim 41, further comprising 
the step of instantiating a Session \fector which identifies the 

10 instantiated Session Object 

45. A method according to claim 35, wherein the appli- 
cation is configured to communicate according to a Telnet 
protocol, and wherein said step of processing comprises the 
step of causing the computer to communicate with the 

IS application according to the Telnet protocol. 

46. A method according to claim 36, wherein said step of 
processing comprises the steps of: 

causing the browser to display a host access Web page 
including a session configuration option; 
20 accepting a user selection of said session configuration 
option from said host access Web page; and 

conducting the session according to the selected configu- 
ration option. 
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